app(app(minus, x), 0) → x
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(f, 0) → app(s, 0)
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(map, fun), nil) → nil
app(app(map, fun), app(app(cons, x), xs)) → app(app(cons, app(fun, x)), app(app(map, fun), xs))
app(app(filter, fun), nil) → nil
app(app(filter, fun), app(app(cons, x), xs)) → app(app(app(app(filter2, app(fun, x)), fun), x), xs)
app(app(app(app(filter2, true), fun), x), xs) → app(app(cons, x), app(app(filter, fun), xs))
app(app(app(app(filter2, false), fun), x), xs) → app(app(filter, fun), xs)
↳ QTRS
↳ Overlay + Local Confluence
app(app(minus, x), 0) → x
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(f, 0) → app(s, 0)
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(map, fun), nil) → nil
app(app(map, fun), app(app(cons, x), xs)) → app(app(cons, app(fun, x)), app(app(map, fun), xs))
app(app(filter, fun), nil) → nil
app(app(filter, fun), app(app(cons, x), xs)) → app(app(app(app(filter2, app(fun, x)), fun), x), xs)
app(app(app(app(filter2, true), fun), x), xs) → app(app(cons, x), app(app(filter, fun), xs))
app(app(app(app(filter2, false), fun), x), xs) → app(app(filter, fun), xs)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
app(app(minus, x), 0) → x
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(f, 0) → app(s, 0)
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(map, fun), nil) → nil
app(app(map, fun), app(app(cons, x), xs)) → app(app(cons, app(fun, x)), app(app(map, fun), xs))
app(app(filter, fun), nil) → nil
app(app(filter, fun), app(app(cons, x), xs)) → app(app(app(app(filter2, app(fun, x)), fun), x), xs)
app(app(app(app(filter2, true), fun), x), xs) → app(app(cons, x), app(app(filter, fun), xs))
app(app(app(app(filter2, false), fun), x), xs) → app(app(filter, fun), xs)
app(app(minus, x0), 0)
app(app(minus, app(s, x0)), app(s, x1))
app(f, 0)
app(f, app(s, x0))
app(g, 0)
app(g, app(s, x0))
app(app(map, x0), nil)
app(app(map, x0), app(app(cons, x1), x2))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
app(app(app(app(filter2, true), x0), x1), x2)
app(app(app(app(filter2, false), x0), x1), x2)
APP(f, app(s, x)) → APP(f, x)
APP(app(minus, app(s, x)), app(s, y)) → APP(minus, x)
APP(app(map, fun), app(app(cons, x), xs)) → APP(app(cons, app(fun, x)), app(app(map, fun), xs))
APP(app(filter, fun), app(app(cons, x), xs)) → APP(app(app(filter2, app(fun, x)), fun), x)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(app(app(app(filter2, app(fun, x)), fun), x), xs)
APP(g, app(s, x)) → APP(app(minus, app(s, x)), app(f, app(g, x)))
APP(f, app(s, x)) → APP(g, app(f, x))
APP(app(app(app(filter2, true), fun), x), xs) → APP(app(cons, x), app(app(filter, fun), xs))
APP(f, app(s, x)) → APP(minus, app(s, x))
APP(app(map, fun), app(app(cons, x), xs)) → APP(fun, x)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(filter2, app(fun, x))
APP(app(minus, app(s, x)), app(s, y)) → APP(app(minus, x), y)
APP(f, app(s, x)) → APP(app(minus, app(s, x)), app(g, app(f, x)))
APP(app(app(app(filter2, true), fun), x), xs) → APP(app(filter, fun), xs)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(app(filter2, app(fun, x)), fun)
APP(app(app(app(filter2, false), fun), x), xs) → APP(filter, fun)
APP(g, app(s, x)) → APP(minus, app(s, x))
APP(app(map, fun), app(app(cons, x), xs)) → APP(app(map, fun), xs)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(fun, x)
APP(app(app(app(filter2, true), fun), x), xs) → APP(filter, fun)
APP(f, 0) → APP(s, 0)
APP(g, app(s, x)) → APP(g, x)
APP(g, app(s, x)) → APP(f, app(g, x))
APP(app(app(app(filter2, true), fun), x), xs) → APP(cons, x)
APP(app(app(app(filter2, false), fun), x), xs) → APP(app(filter, fun), xs)
APP(app(map, fun), app(app(cons, x), xs)) → APP(cons, app(fun, x))
app(app(minus, x), 0) → x
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(f, 0) → app(s, 0)
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(map, fun), nil) → nil
app(app(map, fun), app(app(cons, x), xs)) → app(app(cons, app(fun, x)), app(app(map, fun), xs))
app(app(filter, fun), nil) → nil
app(app(filter, fun), app(app(cons, x), xs)) → app(app(app(app(filter2, app(fun, x)), fun), x), xs)
app(app(app(app(filter2, true), fun), x), xs) → app(app(cons, x), app(app(filter, fun), xs))
app(app(app(app(filter2, false), fun), x), xs) → app(app(filter, fun), xs)
app(app(minus, x0), 0)
app(app(minus, app(s, x0)), app(s, x1))
app(f, 0)
app(f, app(s, x0))
app(g, 0)
app(g, app(s, x0))
app(app(map, x0), nil)
app(app(map, x0), app(app(cons, x1), x2))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
app(app(app(app(filter2, true), x0), x1), x2)
app(app(app(app(filter2, false), x0), x1), x2)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
APP(f, app(s, x)) → APP(f, x)
APP(app(minus, app(s, x)), app(s, y)) → APP(minus, x)
APP(app(map, fun), app(app(cons, x), xs)) → APP(app(cons, app(fun, x)), app(app(map, fun), xs))
APP(app(filter, fun), app(app(cons, x), xs)) → APP(app(app(filter2, app(fun, x)), fun), x)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(app(app(app(filter2, app(fun, x)), fun), x), xs)
APP(g, app(s, x)) → APP(app(minus, app(s, x)), app(f, app(g, x)))
APP(f, app(s, x)) → APP(g, app(f, x))
APP(app(app(app(filter2, true), fun), x), xs) → APP(app(cons, x), app(app(filter, fun), xs))
APP(f, app(s, x)) → APP(minus, app(s, x))
APP(app(map, fun), app(app(cons, x), xs)) → APP(fun, x)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(filter2, app(fun, x))
APP(app(minus, app(s, x)), app(s, y)) → APP(app(minus, x), y)
APP(f, app(s, x)) → APP(app(minus, app(s, x)), app(g, app(f, x)))
APP(app(app(app(filter2, true), fun), x), xs) → APP(app(filter, fun), xs)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(app(filter2, app(fun, x)), fun)
APP(app(app(app(filter2, false), fun), x), xs) → APP(filter, fun)
APP(g, app(s, x)) → APP(minus, app(s, x))
APP(app(map, fun), app(app(cons, x), xs)) → APP(app(map, fun), xs)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(fun, x)
APP(app(app(app(filter2, true), fun), x), xs) → APP(filter, fun)
APP(f, 0) → APP(s, 0)
APP(g, app(s, x)) → APP(g, x)
APP(g, app(s, x)) → APP(f, app(g, x))
APP(app(app(app(filter2, true), fun), x), xs) → APP(cons, x)
APP(app(app(app(filter2, false), fun), x), xs) → APP(app(filter, fun), xs)
APP(app(map, fun), app(app(cons, x), xs)) → APP(cons, app(fun, x))
app(app(minus, x), 0) → x
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(f, 0) → app(s, 0)
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(map, fun), nil) → nil
app(app(map, fun), app(app(cons, x), xs)) → app(app(cons, app(fun, x)), app(app(map, fun), xs))
app(app(filter, fun), nil) → nil
app(app(filter, fun), app(app(cons, x), xs)) → app(app(app(app(filter2, app(fun, x)), fun), x), xs)
app(app(app(app(filter2, true), fun), x), xs) → app(app(cons, x), app(app(filter, fun), xs))
app(app(app(app(filter2, false), fun), x), xs) → app(app(filter, fun), xs)
app(app(minus, x0), 0)
app(app(minus, app(s, x0)), app(s, x1))
app(f, 0)
app(f, app(s, x0))
app(g, 0)
app(g, app(s, x0))
app(app(map, x0), nil)
app(app(map, x0), app(app(cons, x1), x2))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
app(app(app(app(filter2, true), x0), x1), x2)
app(app(app(app(filter2, false), x0), x1), x2)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
APP(app(minus, app(s, x)), app(s, y)) → APP(minus, x)
APP(f, app(s, x)) → APP(f, x)
APP(app(map, fun), app(app(cons, x), xs)) → APP(app(cons, app(fun, x)), app(app(map, fun), xs))
APP(app(filter, fun), app(app(cons, x), xs)) → APP(app(app(filter2, app(fun, x)), fun), x)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(app(app(app(filter2, app(fun, x)), fun), x), xs)
APP(g, app(s, x)) → APP(app(minus, app(s, x)), app(f, app(g, x)))
APP(app(app(app(filter2, true), fun), x), xs) → APP(app(cons, x), app(app(filter, fun), xs))
APP(f, app(s, x)) → APP(g, app(f, x))
APP(f, app(s, x)) → APP(minus, app(s, x))
APP(app(filter, fun), app(app(cons, x), xs)) → APP(filter2, app(fun, x))
APP(app(map, fun), app(app(cons, x), xs)) → APP(fun, x)
APP(app(minus, app(s, x)), app(s, y)) → APP(app(minus, x), y)
APP(f, app(s, x)) → APP(app(minus, app(s, x)), app(g, app(f, x)))
APP(app(app(app(filter2, true), fun), x), xs) → APP(app(filter, fun), xs)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(app(filter2, app(fun, x)), fun)
APP(app(app(app(filter2, false), fun), x), xs) → APP(filter, fun)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(fun, x)
APP(app(map, fun), app(app(cons, x), xs)) → APP(app(map, fun), xs)
APP(g, app(s, x)) → APP(minus, app(s, x))
APP(app(app(app(filter2, true), fun), x), xs) → APP(filter, fun)
APP(f, 0) → APP(s, 0)
APP(g, app(s, x)) → APP(g, x)
APP(g, app(s, x)) → APP(f, app(g, x))
APP(app(app(app(filter2, true), fun), x), xs) → APP(cons, x)
APP(app(app(app(filter2, false), fun), x), xs) → APP(app(filter, fun), xs)
APP(app(map, fun), app(app(cons, x), xs)) → APP(cons, app(fun, x))
app(app(minus, x), 0) → x
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(f, 0) → app(s, 0)
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(map, fun), nil) → nil
app(app(map, fun), app(app(cons, x), xs)) → app(app(cons, app(fun, x)), app(app(map, fun), xs))
app(app(filter, fun), nil) → nil
app(app(filter, fun), app(app(cons, x), xs)) → app(app(app(app(filter2, app(fun, x)), fun), x), xs)
app(app(app(app(filter2, true), fun), x), xs) → app(app(cons, x), app(app(filter, fun), xs))
app(app(app(app(filter2, false), fun), x), xs) → app(app(filter, fun), xs)
app(app(minus, x0), 0)
app(app(minus, app(s, x0)), app(s, x1))
app(f, 0)
app(f, app(s, x0))
app(g, 0)
app(g, app(s, x0))
app(app(map, x0), nil)
app(app(map, x0), app(app(cons, x1), x2))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
app(app(app(app(filter2, true), x0), x1), x2)
app(app(app(app(filter2, false), x0), x1), x2)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDP
APP(app(minus, app(s, x)), app(s, y)) → APP(app(minus, x), y)
app(app(minus, x), 0) → x
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(f, 0) → app(s, 0)
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(map, fun), nil) → nil
app(app(map, fun), app(app(cons, x), xs)) → app(app(cons, app(fun, x)), app(app(map, fun), xs))
app(app(filter, fun), nil) → nil
app(app(filter, fun), app(app(cons, x), xs)) → app(app(app(app(filter2, app(fun, x)), fun), x), xs)
app(app(app(app(filter2, true), fun), x), xs) → app(app(cons, x), app(app(filter, fun), xs))
app(app(app(app(filter2, false), fun), x), xs) → app(app(filter, fun), xs)
app(app(minus, x0), 0)
app(app(minus, app(s, x0)), app(s, x1))
app(f, 0)
app(f, app(s, x0))
app(g, 0)
app(g, app(s, x0))
app(app(map, x0), nil)
app(app(map, x0), app(app(cons, x1), x2))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
app(app(app(app(filter2, true), x0), x1), x2)
app(app(app(app(filter2, false), x0), x1), x2)
MINUS(s(x), s(y)) → MINUS(x, y)
minus(x0, 0)
minus(s(x0), s(x1))
f(0)
f(s(x0))
g(0)
g(s(x0))
map(x0, nil)
map(x0, cons(x1, x2))
filter(x0, nil)
filter(x0, cons(x1, x2))
filter2(true, x0, x1, x2)
filter2(false, x0, x1, x2)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP(app(minus, app(s, x)), app(s, y)) → APP(app(minus, x), y)
s1 > MINUS1
MINUS1: [1]
s1: [1]
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
app(app(minus, x), 0) → x
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(f, 0) → app(s, 0)
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(map, fun), nil) → nil
app(app(map, fun), app(app(cons, x), xs)) → app(app(cons, app(fun, x)), app(app(map, fun), xs))
app(app(filter, fun), nil) → nil
app(app(filter, fun), app(app(cons, x), xs)) → app(app(app(app(filter2, app(fun, x)), fun), x), xs)
app(app(app(app(filter2, true), fun), x), xs) → app(app(cons, x), app(app(filter, fun), xs))
app(app(app(app(filter2, false), fun), x), xs) → app(app(filter, fun), xs)
app(app(minus, x0), 0)
app(app(minus, app(s, x0)), app(s, x1))
app(f, 0)
app(f, app(s, x0))
app(g, 0)
app(g, app(s, x0))
app(app(map, x0), nil)
app(app(map, x0), app(app(cons, x1), x2))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
app(app(app(app(filter2, true), x0), x1), x2)
app(app(app(app(filter2, false), x0), x1), x2)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
APP(f, app(s, x)) → APP(f, x)
APP(g, app(s, x)) → APP(g, x)
APP(g, app(s, x)) → APP(f, app(g, x))
APP(f, app(s, x)) → APP(g, app(f, x))
app(app(minus, x), 0) → x
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(f, 0) → app(s, 0)
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(map, fun), nil) → nil
app(app(map, fun), app(app(cons, x), xs)) → app(app(cons, app(fun, x)), app(app(map, fun), xs))
app(app(filter, fun), nil) → nil
app(app(filter, fun), app(app(cons, x), xs)) → app(app(app(app(filter2, app(fun, x)), fun), x), xs)
app(app(app(app(filter2, true), fun), x), xs) → app(app(cons, x), app(app(filter, fun), xs))
app(app(app(app(filter2, false), fun), x), xs) → app(app(filter, fun), xs)
app(app(minus, x0), 0)
app(app(minus, app(s, x0)), app(s, x1))
app(f, 0)
app(f, app(s, x0))
app(g, 0)
app(g, app(s, x0))
app(app(map, x0), nil)
app(app(map, x0), app(app(cons, x1), x2))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
app(app(app(app(filter2, true), x0), x1), x2)
app(app(app(app(filter2, false), x0), x1), x2)
F1(S(x)) → F1(x)
G(S(x)) → F1(g(x))
F1(S(x)) → G(F(x))
G(S(x)) → G(x)
F(0) → S(0)
F(S(x)) → minus(S(x), g(F(x)))
g(0) → 0
g(S(x)) → minus(S(x), F(g(x)))
minus(x, 0) → x
minus(S(x), S(y)) → minus(x, y)
minus(x0, 0)
minus(S(x0), S(x1))
F(0)
F(S(x0))
g(0)
g(S(x0))
map(x0, nil)
map(x0, cons(x1, x2))
filter(x0, nil)
filter(x0, cons(x1, x2))
filter2(true, x0, x1, x2)
filter2(false, x0, x1, x2)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP(f, app(s, x)) → APP(f, x)
APP(g, app(s, x)) → APP(g, x)
Used ordering: Combined order from the following AFS and order.
APP(g, app(s, x)) → APP(f, app(g, x))
APP(f, app(s, x)) → APP(g, app(f, x))
[S1, g1, F1, minus1] > 0
minus1: [1]
0: multiset
g1: [1]
F1: [1]
S1: [1]
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(f, 0) → app(s, 0)
app(g, 0) → 0
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(app(minus, x), 0) → x
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDPOrderProof
↳ QDP
APP(g, app(s, x)) → APP(f, app(g, x))
APP(f, app(s, x)) → APP(g, app(f, x))
app(app(minus, x), 0) → x
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(f, 0) → app(s, 0)
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(map, fun), nil) → nil
app(app(map, fun), app(app(cons, x), xs)) → app(app(cons, app(fun, x)), app(app(map, fun), xs))
app(app(filter, fun), nil) → nil
app(app(filter, fun), app(app(cons, x), xs)) → app(app(app(app(filter2, app(fun, x)), fun), x), xs)
app(app(app(app(filter2, true), fun), x), xs) → app(app(cons, x), app(app(filter, fun), xs))
app(app(app(app(filter2, false), fun), x), xs) → app(app(filter, fun), xs)
app(app(minus, x0), 0)
app(app(minus, app(s, x0)), app(s, x1))
app(f, 0)
app(f, app(s, x0))
app(g, 0)
app(g, app(s, x0))
app(app(map, x0), nil)
app(app(map, x0), app(app(cons, x1), x2))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
app(app(app(app(filter2, true), x0), x1), x2)
app(app(app(app(filter2, false), x0), x1), x2)
G(S(x)) → F1(g(x))
F1(S(x)) → G(F(x))
F(0) → S(0)
F(S(x)) → minus(S(x), g(F(x)))
g(0) → 0
g(S(x)) → minus(S(x), F(g(x)))
minus(x, 0) → x
minus(S(x), S(y)) → minus(x, y)
minus(x0, 0)
minus(S(x0), S(x1))
F(0)
F(S(x0))
g(0)
g(S(x0))
map(x0, nil)
map(x0, cons(x1, x2))
filter(x0, nil)
filter(x0, cons(x1, x2))
filter2(true, x0, x1, x2)
filter2(false, x0, x1, x2)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP(g, app(s, x)) → APP(f, app(g, x))
APP(f, app(s, x)) → APP(g, app(f, x))
[S1, F11, F1] > 0 > G1
G1: [1]
F11: [1]
0: multiset
F1: [1]
S1: [1]
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(f, 0) → app(s, 0)
app(app(minus, x), 0) → x
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
app(app(minus, x), 0) → x
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(f, 0) → app(s, 0)
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(map, fun), nil) → nil
app(app(map, fun), app(app(cons, x), xs)) → app(app(cons, app(fun, x)), app(app(map, fun), xs))
app(app(filter, fun), nil) → nil
app(app(filter, fun), app(app(cons, x), xs)) → app(app(app(app(filter2, app(fun, x)), fun), x), xs)
app(app(app(app(filter2, true), fun), x), xs) → app(app(cons, x), app(app(filter, fun), xs))
app(app(app(app(filter2, false), fun), x), xs) → app(app(filter, fun), xs)
app(app(minus, x0), 0)
app(app(minus, app(s, x0)), app(s, x1))
app(f, 0)
app(f, app(s, x0))
app(g, 0)
app(g, app(s, x0))
app(app(map, x0), nil)
app(app(map, x0), app(app(cons, x1), x2))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
app(app(app(app(filter2, true), x0), x1), x2)
app(app(app(app(filter2, false), x0), x1), x2)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
APP(app(app(app(filter2, true), fun), x), xs) → APP(app(filter, fun), xs)
APP(app(map, fun), app(app(cons, x), xs)) → APP(fun, x)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(app(app(app(filter2, app(fun, x)), fun), x), xs)
APP(app(app(app(filter2, false), fun), x), xs) → APP(app(filter, fun), xs)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(fun, x)
APP(app(map, fun), app(app(cons, x), xs)) → APP(app(map, fun), xs)
app(app(minus, x), 0) → x
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(f, 0) → app(s, 0)
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(map, fun), nil) → nil
app(app(map, fun), app(app(cons, x), xs)) → app(app(cons, app(fun, x)), app(app(map, fun), xs))
app(app(filter, fun), nil) → nil
app(app(filter, fun), app(app(cons, x), xs)) → app(app(app(app(filter2, app(fun, x)), fun), x), xs)
app(app(app(app(filter2, true), fun), x), xs) → app(app(cons, x), app(app(filter, fun), xs))
app(app(app(app(filter2, false), fun), x), xs) → app(app(filter, fun), xs)
app(app(minus, x0), 0)
app(app(minus, app(s, x0)), app(s, x1))
app(f, 0)
app(f, app(s, x0))
app(g, 0)
app(g, app(s, x0))
app(app(map, x0), nil)
app(app(map, x0), app(app(cons, x1), x2))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
app(app(app(app(filter2, true), x0), x1), x2)
app(app(app(app(filter2, false), x0), x1), x2)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP(app(map, fun), app(app(cons, x), xs)) → APP(fun, x)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(app(app(app(filter2, app(fun, x)), fun), x), xs)
APP(app(filter, fun), app(app(cons, x), xs)) → APP(fun, x)
APP(app(map, fun), app(app(cons, x), xs)) → APP(app(map, fun), xs)
Used ordering: Combined order from the following AFS and order.
APP(app(app(app(filter2, true), fun), x), xs) → APP(app(filter, fun), xs)
APP(app(app(app(filter2, false), fun), x), xs) → APP(app(filter, fun), xs)
filter2 > cons > APP1 > [app2, false] > minus > [filter, map, nil]
true > cons > APP1 > [app2, false] > minus > [filter, map, nil]
[0, f] > [s, g] > [app2, false] > minus > [filter, map, nil]
APP1: [1]
map: multiset
0: multiset
s: multiset
minus: multiset
nil: multiset
cons: multiset
filter: multiset
true: multiset
false: multiset
app2: [1,2]
f: multiset
filter2: multiset
g: multiset
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ DependencyGraphProof
APP(app(app(app(filter2, true), fun), x), xs) → APP(app(filter, fun), xs)
APP(app(app(app(filter2, false), fun), x), xs) → APP(app(filter, fun), xs)
app(app(minus, x), 0) → x
app(app(minus, app(s, x)), app(s, y)) → app(app(minus, x), y)
app(f, 0) → app(s, 0)
app(f, app(s, x)) → app(app(minus, app(s, x)), app(g, app(f, x)))
app(g, 0) → 0
app(g, app(s, x)) → app(app(minus, app(s, x)), app(f, app(g, x)))
app(app(map, fun), nil) → nil
app(app(map, fun), app(app(cons, x), xs)) → app(app(cons, app(fun, x)), app(app(map, fun), xs))
app(app(filter, fun), nil) → nil
app(app(filter, fun), app(app(cons, x), xs)) → app(app(app(app(filter2, app(fun, x)), fun), x), xs)
app(app(app(app(filter2, true), fun), x), xs) → app(app(cons, x), app(app(filter, fun), xs))
app(app(app(app(filter2, false), fun), x), xs) → app(app(filter, fun), xs)
app(app(minus, x0), 0)
app(app(minus, app(s, x0)), app(s, x1))
app(f, 0)
app(f, app(s, x0))
app(g, 0)
app(g, app(s, x0))
app(app(map, x0), nil)
app(app(map, x0), app(app(cons, x1), x2))
app(app(filter, x0), nil)
app(app(filter, x0), app(app(cons, x1), x2))
app(app(app(app(filter2, true), x0), x1), x2)
app(app(app(app(filter2, false), x0), x1), x2)